# NOTICE

THIS DOCUMENT HAS BEEN REPRODUCED FROM MICROFICHE. ALTHOUGH IT IS RECOGNIZED THAT CERTAIN PORTIONS ARE ILLEGIBLE, IT IS BEING RELEASED IN THE INTEREST OF MAKING AVAILABLE AS MUCH INFORMATION AS POSSIBLE

# LOGIC SYNTHESIS FROM DDL DESC'

# rrepared

SAJJAN G. SHIVA
Computer Science Department
THE UNIVERSITY OF ALABAMA IN HUNTSVILLE
Huntsville, Alabama 35807

(NASA-CR-161386) LOGIC SYNTHESIS FROM DDL DESCRIPTION Quarterly Progress Report, 1 Oct. - 31 Dec. 1979 (Alabama Univ. in Huntsville.) 18 p HC A02/MF A01 CSCL 09B

N82-20905

Unclas G3/61 16743

January 1980

Fifth Quarterly Progress Report
October 1, 1979 - December 31, 1979
Contract NASS-33096
"DESIGN SYNTHESIS OF DIGITAL SYSTEMS"
George C. Marshall Space Flight Center
Alabama, 35812



### FORWARD

This is a technical summary of the progress made since October 1, 1979 by The University of Alabama in Huntsville towards the fulfillment of the contract NASS-33096, from the George C. Marshall Space Flight Center, Alabama. The NASA Technical officer for this contract is Mr. Robert E. Jones, Electronics and Controls Laboratory.

# LOGIC SYNTHESIS FROM DDL DESCRIPTION

The implementation of DDLTRN and DDLSIM programs on SZL-32 Computer System is now complete. These programs were tested with DDL descriptions of various complexity. Testing with newer system descriptions will continue.

An algorithm to synthesize the combinational logic using the cells available in the standard IC cell library was formulated. This algorithm is now being implemented as a FORTRAN program. A description of the algorithm is given in the Appendix.

Some corrections were made to the MINICOMPUTER description (Example 5) in the First Annual Technical Report. An updated version of the description and the corresponding simulation results are shown in Figure 1.

The future work includes the completion of logic synthesis algorithm implementation, extension of the algorithm to include the synthesis of memory elements, registers and the register-transfer equations.

# DIGITAL DESIGN LANGUAGE TRANSLATOR

```
<SY>MINI:
                    <HE>MAR(0:7),MBH(0:11),FC(0:7),ACC(0:11).
              5:
              3:
                    <RE>IR(0:11)=OP(3)(IBIT(ADR(8),RUN.
                    <RE> X(0:11).
              4:
              5:
                    <ME>M(256:12).
4
              6:
                    <TE>MBUS(12).
. *
              7 :
                    <LA>STAHT.
              8:
                    <TE>P(4).
143.
              9:
                    <TI>H.
                                                          Figure 1(a)
4
             10:
                    <OP>CNTUP(8)SXS
                                                           MINI Computer Description
41 64
                        <TE>X(8),C(8).
             11:
                                                           (DDLTRN Input)
                        <10>CC=(C(2:8)(1D1).
             12:
                        <BO>C=X*CC,CNTUP=X&CC...
             13:
14:
                    <0P>SUM(12) $X, YE
             15:
                        <TE>X(12),C(12),Y(12),COLT(12).
***
             16:
                        <10>CIN=COUT(2:12)(001.
             17:
                        <60>COUT=X*Y+X*ClN+Y*ClN,
             18:
                            SUM=XaYaCIN..
             19:
                    <AU>CLK(2):R:
                        <$1>$(0):$TAKT:P=804,->T.
             20:
                                                            ORIGINAL PAGE 18
             21:
                            T(1):P=404,->J.
                                                             OF POOR QUALITY
             22:
                            J(2):P=2D4,->L.
             23:
                            L(3):P=104,->S...
             24:
                    <AU>CPU(4):R:
                         <ST>1N(0):START:]F(4)]ACC<=0,MAR<=PC,MER<=0,X<=0,</pre>
             25:
             26:
                                          RUN <- 1, -> FE ..
                             FE(1):RUN:]P(1)]MAR<-PC.,]P(2)]PC<-CNTUP&PC%,
             27:
             28:
                                        MBUS=M(MAR),MBR<-MBUS.,JP(3)]IR<-MBR.,
             29:
                                        JP(4)]]OP(1)*UP(2)*OP(3)]RUN<-0,->IN;
```

```
30:
           31:
                         DEF(2): JP(1) JVAR < - ACF., JP(2) JVBUS = N (MAR), MBR < - NBUS.,
           32:
                               33:
                         EX(3):P(4):10P#003->XAND #103 ->XAND #203 ->XISZ
           34:
                                #3D3 ->XUCA #4D3 ->XJSR #5D3 ->XJMP #6D3 ->XRE
           35":"
                          36:
                                1P(3)1PBUS=P(MAR), PBR<-MBUS.,
           37:
                                35:
                          XISZ(5):)P(1))MAR<-ADR.,
           39:
                                TP(2)TMBUS=M(MAR),MBR<-MBUS.
           40:
                                JP(3)] YER <- SUMSMBR, 10123.,
           41:
                                TP(4)TREUS=RER;M(WAR)<-RBUS,]+(+/MBR)]
           42:
                                     PC<-CNTUPSPCS.,->FE..
           43:
                         XDCA(6):1P(1)1MER<-ACC.,1P(2)1MAR<-ADR.,
1
           44:
                                TP(3)TACC<-0,MBUS=MBR,M(MAR)<-MBUS.,1P(4)1
           45:
                         46:
                               TP(3)TVBUS=MER,M(MAR)<-MBUS.,
           47:
                               "P(4))PC<-ACR,->FE:-
¥1. Y
           48:
                          XRET(6):)F(1)TMAR<-0.,JP(2)JMBUS=M(MAR),
           49:
                                MBR<-MBUS.7)P(4))PC<-MBR(4:11)7->FE...
           501
                           XJMP(9):1P(1))PC<-ADR.71P(4))->FE:
                <FL>3,4,5,6,8.
*
                           Figure 1(a): Continued
4
          <fL>4,8
          <IN>M(0:3)/5,6,7,8
          <1N>M(4:7)/4092,0,0,0
          <IN>M(8:14)/5,774,1030,1028,2569,1543,3584
                                                     ___Figure 1(b):
          <RE>IN/PC/8
A ...
          <IN>START/1/
                                                       DDLSIM Input
          ZOU>IN/CPU, IR, PC, MAR/
          <OU>FE/MAR,MAR,IR,PC,ACC/
          <OU>EX/MAR, MBR, IR, PC, ACC/
          <SI>
                                        ORIGINAL PAGE IS
          SECJ
                                        OF POOR QUALITY
```

| DIGITAL | DESIGN L | ANGUAGE | SIMULATOR |
|---------|----------|---------|-----------|
|---------|----------|---------|-----------|

OF FILE REACHED ON INPUT
STMULATION TERMINATED AT TIME = 457

| ν | F  | E S | T   | n | N | "N | SF  | C: | 19 | 79  |
|---|----|-----|-----|---|---|----|-----|----|----|-----|
| v | E. |     | , , | u |   | 17 | J F |    | 17 | , , |

SIMULATION, RUN

| 4 <b>9</b> 7  |                                         |                                            | annets annual |                                  | of Po | OR Qu   |        | * * * * * |     | Three and              |                               |                                                                                                                 |     |                                                        |
|---------------|-----------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------------------------|-------|---------|--------|-----------|-----|------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------|
|               | C                                       |                                            |                                                                                                                 |                                  |       |         |        |           |     |                        |                               |                                                                                                                 |     |                                                        |
| TIME          | P<br>U                                  | IR                                         | PC                                                                                                              | MAP                              | MAR   | MBR     | Ik     | PC        | ACC | MAR                    | MBR                           | 1R                                                                                                              | PC  | ACC                                                    |
| o Children    | 00                                      | 0000                                       | 000                                                                                                             | 000                              |       |         |        |           |     |                        |                               |                                                                                                                 |     |                                                        |
| 16            |                                         |                                            |                                                                                                                 |                                  |       |         | 0000   |           |     | 008                    | 0005                          | 0005                                                                                                            | 009 | 0000                                                   |
| 32            |                                         |                                            |                                                                                                                 |                                  |       |         | * 0005 |           |     | 006                    | 0000                          | 0768                                                                                                            | 010 | 0000                                                   |
| 72            | •                                       |                                            |                                                                                                                 |                                  |       |         | 0768   |           |     | 010                    | 1030                          | 1030                                                                                                            | 011 | 0005                                                   |
| 88<br>96      |                                         |                                            |                                                                                                                 |                                  |       |         | 1030   |           |     | 011                    | 1028                          | 1028                                                                                                            | 012 | 0005                                                   |
| 112           |                                         |                                            |                                                                                                                 |                                  |       |         | 1058   |           |     | 012                    | 2569                          | 2569                                                                                                            | 013 | 0005                                                   |
| 136<br>152    |                                         |                                            | property and                                                                                                    |                                  |       |         | 2569   |           |     | 006                    | 0001                          | 0769                                                                                                            | 010 | 0005                                                   |
| 168<br>176    |                                         | ng makad birmay akao na kabupaga           |                                                                                                                 |                                  |       |         | 0769   | - '       |     | 0 1:0                  | 1030                          | 1030                                                                                                            | 011 | 0011                                                   |
| 192<br>200    | -                                       |                                            |                                                                                                                 |                                  |       |         | 1030   |           |     | 011                    | 1028                          | 1028                                                                                                            | 012 | 0011                                                   |
| 216<br>224    | <del>,</del>                            | ng aya magamining samulutay sakini aningsa | nada primirali de nase cain                                                                                     | ni è <u>amin'ilente</u> s'esse a |       |         | 1028   |           |     | 012                    | 2569                          | 2569                                                                                                            | 013 | 0011                                                   |
| 240<br>256    | *************************************** |                                            |                                                                                                                 |                                  |       |         | 2569   |           |     | 006                    | 0002                          | 0770                                                                                                            | 010 | 0031                                                   |
| 272<br>280    |                                         |                                            |                                                                                                                 | المنتب                           |       | , - , , | 0770   | •         |     | 0.1:0                  | 1030                          | 1030                                                                                                            | 011 | 0018                                                   |
| 296<br>304    |                                         | garinanskister Verkenska                   | ngo de George Schola Min                                                                                        | nia pagi Pinnaiana alis da       |       |         | 1030   |           |     | 011                    | 1028                          | 1028                                                                                                            | 012 | 0018                                                   |
| 320<br>4. 328 |                                         |                                            | gande de l'ille de la spira de l'agranda de l'agranda de l'agranda de l'agranda de l'agranda de l'agranda de l  | an and the second special second |       |         | 1028.  |           |     | 012                    | 2569                          | 2569                                                                                                            | 013 | 0018                                                   |
| 344<br>360    |                                         |                                            |                                                                                                                 |                                  |       |         | 2569   | •         |     | 006                    | 0003                          | 0771                                                                                                            | 010 | 0018                                                   |
| 376<br>384    |                                         | ·                                          |                                                                                                                 |                                  |       |         | 0771   |           |     | 0 10                   | 1030                          | 1030                                                                                                            | 011 | 0026                                                   |
| \$ 400<br>408 | ,                                       |                                            |                                                                                                                 |                                  |       |         | 1030   |           |     | 011                    | 1028                          | 1028                                                                                                            | 012 | 0500                                                   |
| 424<br>432    | ·                                       |                                            |                                                                                                                 | •                                |       |         | 1028   |           |     | 013                    | 1543                          | 1543                                                                                                            | 014 | 0026                                                   |
| 448<br>456    | 00                                      | 3584                                       | 015                                                                                                             | 014                              |       | UVED    | 1543   | 014       |     | worther inschange of a | Maring a garage of the second | C CENTRAL OF SOURCE STORE - AND STORE - |     | Terming 19 7 - 11 - 12 - 12 Alba Janabahara a summer a |
| 7             |                                         |                                            |                                                                                                                 |                                  |       |         |        |           |     |                        |                               |                                                                                                                 |     |                                                        |

Figure 1 (c): DDLSIM Output

# APPENDIX

# COMBINATIONAL LOGIC SYNTHESIS FROM AN HDL DESCRIPTION\*

Sajjan G. Shiva

Computer Science Department
The University of Alabama in Huntsville
P.O. Box 1247
Huntsville, Alabama 35807
(205) 895-6088

# ABSTRACT

Hardware Description Languages are used to input the details of a digital system into an automatic design system. An algorithm to synthesize combinational logic from the description in one such language (DDL) is discussed.

\*Submitted to the 17th Design Automation Conference Minneapolis, Minn. June 1980.

### 1. INTRODUCTION

Hardware Description Languages (HDL) provide a convenient means of inputting the digital system design details into a design automation system. Although HDLs were originally designed to be just description media, they have been used in other functions such as simulation, fault test generation, microcode generation, documentation, etc.. The use of HDLs in LSI design automation systems is not widespread because of the difficulty in translating the HDL description into logic diagrams (or connectivity lists or equivalent), non-familiarity of the hardware designers with high-level language programming aspects, non-uniform design methodologies and the time and cost involved in transporting and tailoring the HDL software developed at one design center to the other. However, the advent of VLSI forces that the design be thoroughly verified at the earliest possible time in the design cycle to minimize the fabrication costs brought about by the final changes in a design. Since a suitable breadboard for a VLSI circuit is the VLSI circuit itself, a thorough computer evaluation at the outset is mandatory. Figure 1 [1,2] shows the complete schematic of an IC design automation system. Computer Aided Design and Test System (CADAT) of the NASA Marshall Space Flight Center [1] is organized as in Figure 1. Digital Systems Design Language (DDL) [3] has been selected [1] for the CADAT system. paper addresses the problem of hardware compilation from the DDL description, i.e., the process of converting the output of the DDL translator into logic diagrams (or connectivity list, net list, etc.).

# 2. DDL TRANSLATOR [3]

The DDL translator converts the DDL description of the digital system into a facility table, a set of Boolean equations and a set of

register transfer equations. Figure 2 shows an example description.

.e Boolean equations generated by the translator are in Sum of Products

(SOP) form. The Boolean functions in the DDL description that were not in the SOP form are retained as they are by the translator. The designer can thus generate all the Boolean equations in the SOP form only if he desires. Hence, the synthesis procedure discussed here assumes a SOP form for the Boolean functions.

### 3. THE STANDARD CELL LIBRARY

Table 1 shows a partial list of the standard cells available in the CADAT system. Number of devices for each cell and the cell width (as a measure of the silicon area needed) are also shown. The last column shows the literals in each product term of the function realized by the cell. Note that the patterns containing all 1s (11, 111, 1111) and those with one product term (1, 2, 3, 4) correspond to a single gate realization. It is desirable to realize a function by using larger standard cells (if possible), as shown by the implementations shown in Figure 3 for an example Boolean function. The standard cell library provides four cells that can realize a larger function than a gate equivalent, i.e., 2222, 2112, 222, and 22. Also note that the maximum number of inputs to a cell is 8 (2222). Hence, we limit the number of literals in a Boolean function to be realized to 8. A function larger than this needs to be realized in several 8 literal units. For example,

Z = P + Q where P and Q are 8-literal units

<sup>=</sup>  $\overline{P} \cdot \overline{Q}$   $\overline{F}$  and  $\overline{Q}$  are separately realized. A NAND cell is used to combine them to form Z

### 4. THE SYNTHESIS ALGORITHM

- 1) Scan the Boolean function to be implemented and count the number of literals in each product term to generate the literals/product term pattern for the function.
- 2) If the function pattern is that of a SUM term (patterns containing onl; ls: 1, 11, 111, etc.): implement using the NOR cells with proper number of inputs followed by a NAND cell; stop.
- 3) If the function pattern is that of a PRODUCT term (patterns 2, 3, 4, etc.): implement using the NAND cells with proper number of inputs followed by a NOR cell; stop.
- 4. Reduce the product terms with more than 2 literals into a term with 1 literal (these terms are implemented as in Step 3). If the function pattern reduces to all 1s go to Step 2, else proceed.
- 5. Scan the function pattern to identify the retandard patterns: 2222, 2211, 222, 22 in that order. Eliminate the matching portion of the function pattern if the patterns or partial patterns are found (A partial pattern is one which matches the standard cell pattern everywhere except in one digit, for example:

2221 is implemented as 2222

2111 is implemented as 2211

- 21 is implemented as 22)
- Note that the algorithm does not minimize the Boolean function.

  Only the literals are counted, not the actual number of input variables needed. This might result in slightly higher cost implementations of some functions when the same input variable repeats. For example:

### A + BE + CDE

could be implemented with two cells: 1880 and 1220. (14 devices, 20.7 mils). Using the algorithm:

|      |    | Λ  | 4. | BE    | 4 | CDE    |      |   |
|------|----|----|----|-------|---|--------|------|---|
| Step | 1) | 1. | 2  |       | 3 |        |      |   |
| Stop | 4) | 1  | 2  |       | 1 |        |      |   |
| Step | 5) | 口  | 2  | ***** | 1 |        |      |   |
| Step | 2) |    | 2  |       | 1 | ← From | Step | 5 |

The implementation needs three cells: 1870 and 3, 1220s assuming that  $\overline{\Lambda}$  is not available. The cost is (20 devices, 27 mils).

### CONCLUSIONS

An algorithm for selecting standard cells for implementing the combinational logic is presented. The algorithm is suitable for implementation as a computer program. The complete synthesis algorithms for the CADAT system are now being investigated. These algorithms extend the algorithm presented here to include the memory cells (flip-flops) and corresponding register-transfers. But the algorithm presented here is suitable for any LSI design environment.

### ACKNOWLEDGEMENTS

This work is supported by the NASA-Marshall Space Flight Center under the contract NAS8-33096.

### REFERENCES

- [1] S. G. Shiva, "Use of DDL in an Automatic LSI Design System,"

  Proc. International Symp. CHDLs, Palo Alto, CA, October 1979,

  pp. 28-32.
- [2] \_\_\_\_, "Hardware Description Languages A Tutorial," Proc. IEEE,

  Dec. 1979.

[3] D. L. Dietmever and J. R. Duley, "Register Transfer Languages and Their Translation," in <u>Digital Systems Design Automation: Languages</u>, <u>Simulation and Data Base</u>, M. A. Breuer (ed), Computer Sciences Press, Woodland Hills, CA, 1975.

Table 1: CADAT Standard Cell Library (Fartial)

| Cell No. | Тура                           | No. of<br>Devices | Cell Width<br>(mils) | Function                      | Literals/Product<br>Term |
|----------|--------------------------------|-------------------|----------------------|-------------------------------|--------------------------|
| 1120     | 2 input NGR                    | 4                 | 5.8                  | $\overline{A} + \overline{B}$ | 1,1                      |
| 1130     | 3 Input NIR                    | 6                 | 7.7                  | A + B + C                     | 1,1,1                    |
| 1140     | 4 input NOR                    | 8                 | 9.6                  | A + B + C + D                 | 1,1,1,1                  |
| 1220     | 2 input NAND                   | 4                 | 5.8                  | A·B                           | 2.                       |
| 1230     | 3 input NAND                   | 6                 | 7.7                  | A · B · C                     | 3                        |
| 1240     | 4 input NAND                   | 8                 | 9.6                  | A • B • C • D                 | 4                        |
| 1310     | Buffer Inverter                | 2                 | 3.9                  | 7                             | 1                        |
| 1620     | 2 input AND                    | 6                 | 5.8                  | Ā∙B                           | 2                        |
| 1630     | 3 input AND                    | 8                 | 7.7                  | A+B+C                         | 3                        |
| 1640     | 4 input AND                    | 10                | 9.6                  | A·B·C·D                       | 4                        |
| 1720     | 2 input OR                     | 6                 | 5.8                  | A + B                         | 1,1                      |
| 1730     | 3 input OR                     | 8                 | 7.7                  | A + B + C                     | 1,1,1                    |
| 1740     | 4 input OR                     | 10                | 9.5                  | A + B + C + D                 | 1,1,1,1                  |
| 1800     | 4 x 2 input AND + 4 x NOR      | 16                | 17.2                 | (AB + CD + EF + GII)          | 2,2,2,2                  |
| 1840     | 3 x 2½ input AND + 2 input NOR | 10                | 11.6                 | G(AB + DE)*                   | _                        |
| 1960     | 2 x 2 input AND + 4 input NOR  | 12                | 13.7                 | AB + E + F + CD               | 2,1,1,2                  |
| 1870     | 2 x 2 input AND + 2 input NOR  | 8                 | 9.6                  | (AB + CD)                     | 2,2                      |
| 1880     | 2 bit carry<br>Anticipate      | 10                | 14.9                 | (CDE) + BE + A*               | -                        |
| 1890     | 3 x 2 input AND + 3 input NOR  | 12                | 16.9                 | AB + CD + EF                  | 2,2,2                    |
| 2310     | 2 input EXOR                   | 8                 | 7.8                  | A @ B                         | 1,1                      |

<sup>\*</sup> Special Functions



Figure 1 : Digital System Design Automation Process

# DIGITAL DESIGN LANGUAGE TRANSLATOR

\* <SY>COMPLEMENTER:

2: <\E>\((1:6),C(2:0),S,1.

3: <L3>S.

: <11>+:

: <0P> 400(3)4XE

<10> CC=(((2:3))(10)).

td:dAGJ<ny> :

10: <51>I(0):Sm:1<-1,C<-0,S<-0,->S1.

\$1(1):1:181 + (1)<++=(6),=(2:5)<+=(1:5) ;S<+=(6),F<-=(6)[F(1:5)., ••

2: ]C(2)\*TC(1)\*C(6)]]<-0,->I;C<-4AD\$C>....

13: <FL>3,4,5,6,8.

ORIGINAL PAGE IS

Figure 2(a): DDL Description of a 6 Bit Serial Twos Complementer

FACILITY TABLE

| Ç        | Ö      | 0          | O.  | 325        |            | <b>၁</b>     | 0        |            | 219 | ပ            |            |            |         | 20.0      |     | 0         |               | 287      |        | S    | Ġ  | 0      |      | 19 | U           | 511 |     |     |
|----------|--------|------------|-----|------------|------------|--------------|----------|------------|-----|--------------|------------|------------|---------|-----------|-----|-----------|---------------|----------|--------|------|----|--------|------|----|-------------|-----|-----|-----|
| 0        | 0      | S          | 162 | 2          | O          | O            | 0        | 9          | 0   | O            | ن          | 330        | 2       | •>        | ت   | ပ         | c             | Ö        | 9      | Û    | ၁  | c      | c    | 0  | ت           | 0   |     | 182 |
| 339      |        | N          | 235 |            | ŷ          | r)           | ¢        | 191        | 213 | 0            | V          | 7.24       | Ö       | 203       | ت   |           | U.            | 250      | C      | M    | 0  | ာ      | -    | Z  | 20          | 007 | 'nΛ |     |
| O        | Ç      | ۍ          | O   | ÷          | æ.         | Ö            | Ö        | Ö          | ဇ   | 9            | ÷          | •          | ဇ       | Ō         | =   | =         | 0             | 0        | ÷      | ာ    | c  | ر<br>ت | ଦ    | O  | o           | Ç   | ©.  | 0   |
|          | ٠<br>• | į.         | ۵   | ţ          | <b>د</b>   | ìV           | <b>6</b> | <b>o</b>   | 0   | or<br>•      | O.         | ·C         | -13     | -13       | -17 | -17       | 5.            | J.       | oʻ     | 0    | 0  | ٥      | 11   | 11 | Ľ           | αſ  | N   | ~   |
|          | £      | بر,<br>ا   |     | -          | <b>-</b> - | <u>, -</u> - | m        | ۱۲۱        |     | , <b>v</b> , |            |            | سب      | -1        | p=4 | <b></b> 1 |               |          | 7      | _    | C' | c      |      | ~  | <b>,-</b> - | Λį  | u)  | #1  |
|          | Ç      | င          |     | -          | ÷-r        | -            | M        | ~          |     | 1~1          | ₩          |            | J       |           |     | C         |               | -        | -      | ~    | C. | 9      | ۲۱   | Ŋ, | 143         | ~   | æ,  |     |
| -        |        | N          | 7   | 7          |            | -            | -        | <b>.</b> - | -   | ~            | <b>,</b> - | <b>-</b> - | 17      | .U        | 4   |           | -             | <b>,</b> | -      |      | ۵  | Ò      | re"j | _  | اما         | -   | ٨ı  | -   |
| LEWENTER | CL.    | ပ          | y)  | <b>بخو</b> | ÷.         | <b>a.</b>    | AFe      | <b>34,</b> |     |              | ~=         | COMP       | <b></b> | 51        | 101 | Ô         | <u>د</u><br>م |          | ء<br>س | TO S |    |        | ້ວ   | =  | 12          |     | iz  | œ   |
| ٠,-      | (V)    | <b>~</b> 1 | 3   | ķΛ         | Ü          | 7            | a)       | Ų          | ٦¢  | 11           | ~          | ٠<br>ابرا  | 7       | اري<br>سا | ç   | 2.1       | 4             | ٠<br>ح   |        |      |    |        |      |    |             | 22  |     |     |

ORIGINAL PAGE IS OF POOR QUALITY

```
Register Transfers
                                                                               Combinational Logic
                                                                                                                                                                                                                                               F(2:5)<-"3*P(1:5) + "c*E(1:5),,
                                                                                                                                                                                                                                   R(1)<-"3×1R(6) + "ux+(n)."
                                                                                                                                                                 + "5×0" +
                                                                                                                                                                                         + "4+F(c).
                                                                                                                                     APP (1:2)=(X(1:2) 4C"1(2:3)),
                                                                                                          C"1(1:2)=x(1:2)+C"1(2:3),
                                                                                                                                                                                                         CGvP<-"1+101
                                                                                           "6="2*!(E(2)*1E(1)*C(0)),
                                                                                                                                                               I<-"1*![1
                                                                              "S="2*C(2)*tC(1)*C(0),
                                                                                                                                                                                          0 * 1 1 -> 3
                                                                                                                                                                              1+1 ...>J
                                                                                                                                                  305(3)=(x(3)9161
                                                                                                                       C"1(3)=X(3)+101
                                                                                                                                                                £*#5]
                                                                                                                                                                          [9#+a
                                                                                                                                                                                        [74+4
                                                                                                                                                                                                     [S.*a
                                                                                                                                                                                                                                            [b<sub>H</sub>≠a
                                                                                                                                                                                                                                   [ " " * d
           S1=*/(Gr P'101
]=*/CUNPIN
                                                                "42" 24 +S.
                         "1=1+5",
                                      "Z=51*T,
                                                    "3="2+S"
                                                                                                                                                                                                                                              $ 2444[
                                                                                                                                                                                                                                                           X="6xC,
                                                                                                                                                                                                                                  M= +1.
                                                                                                                                                               1140
                                                                                                                                                                             1141
                                                                                                                                                                                          1444
                                                                                                                                                                                                       L # d
```

SYN LEWENTER:

```
* = AND, \uparrow = NOT, \emptyset = EXOR, + = OR, \leftarrow = Transfer, \rightarrow = GO TO
                                                                                                                                                                                                            " is part of the variable name
                                                                                                                                                                   Commas separate the equations
                                                                                                                     1D1 = 1 bit Decimal 1.
                                                             = IF ... THEN
NOTES:
```

Figure 2(c): DDL Translator Output Equations

AB + CD + EF + G

Function to be implemented

2 2 2 1

Pattern

|   | Implementation  | Cells Needed | No. of Devices | Area (Mils) |
|---|-----------------|--------------|----------------|-------------|
| 1 | 2 2 2 1 2 2 2 2 | 1800         | 1.6            | 17.2        |
|   |                 | 1220         | 4              | 5.8         |
|   | *Total Cost     |              | 20             | 23.0        |
| 2 | 22 21           |              |                |             |
|   | 22 22           | 1870         | 8              | 9.6         |
|   |                 | 1870         | 8              | 9.6         |
|   |                 | 1220         | 4              | 5.8         |
|   | Total Cost      |              | 20             | 25.0        |
| 3 | [2][2][1]       | 4 x 1220     | 16             | 23.2        |
|   |                 | 1240         | 8              | 9.6         |
|   | Total Cost      |              | 24             | 32.8        |

<sup>\*</sup> Least Cost Implementation

# ORIGINAL PAGE IS OF POOR QUALITY